Spinner下拉式選單
這也很常用在表單中
如:選擇地區、居住地、選擇語言、學校
那今天就來學習點選按鈕後抓到我目前是選哪個選項八
這個Spinner元件裡面選項可由我們自己設定 把需要的選項以固定格式寫在app -> res/values/strings.xml內
固定格式:
<string-array name="test">
    <item>item1</item>
    <item>item2</item>
    <item>item3</item>
    <item>item4</item>
</string-array>
到activity_main.xml後
先到palette欄內的Containers找到Spinner選單元件,並拉出一個
在拉出我們熟悉的按鈕Button
最後來個TextView顯示結果
(Design頁做設計)
之後在Design頁點選Spinner後,在右上角的Properties找到entries屬性設定成@array/test
(string array name=”test”的name是什麼@array/後面就是什麼)

Or
(Code頁做設計)
在Spinner裡新增android:entries="@array/test"
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">
    <Spinner
        android:id="@+id/spinner"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="90dp"
        android:entries="@array/test"
        android:minHeight="48dp"
        android:textAlignment="center"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
    <Button
        android:id="@+id/btn_1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="10dp"
        android:text="顯示"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/spinner" />
    <TextView
        android:id="@+id/tv_result"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="30dp"
        android:text="TextView"
        android:textSize="30dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/btn_1" />
</androidx.constraintlayout.widget.ConstraintLayout>
這邊有兩個藥學的程式碼
package com.example.spinner;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Spinner;
import android.widget.TextView;
public class MainActivity extends AppCompatActivity {
    TextView tv_result;
    Spinner spinner;
    Button btn_1;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        tv_result = findViewById(R.id.tv_result);
        spinner = findViewById(R.id.spinner);
        btn_1 = findViewById(R.id.btn_1);
        btn_1.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                String[] temp = getResources().getStringArray(R.array.test);
                int index = spinner.getSelectedItemPosition();
                tv_result.setText("你選取:"+temp[index]);
            }
        });
    }
}
執行結果:
初始畫面
選取item3的畫面
明天學:點選選項後馬上執行選項所對應的程式碼